## Bug-9 Report Group-8

- 1. Failing Test Name: MESI Testing for the data cache, MSI sequence testing
- 2. Test Description(Describe the planned scenario and the expected result):

Testing the MESI protocol by simulating multiple scenarios such as Modified to Shared, Exclusive to Invalid sequence etc. In the MSI test, we write to an address through 1st core, causing write miss, then read that address through 2nd core, causing read miss and modify the data through the 2nd core, causing read hit, to test if the data becomes invalid in 1st core.

## 3. Failing assertion that helped you identify the bug

In the scoreboard we noticed that there was a system bus mismatch while expected data was received. We looked into the waveforms and looked into the MESI states of all processors involved in the test case. We noticed that the current\_mesi\_snoop signal never transitions to show shared state even though the updated\_mesi\_snoop signal is changed. We looked at other signals related to MESI transactions. When looking at the access\_blk\_snoop, we noticed the signal was zero when it was supposed to be high. According to the HAS document, the access\_blk\_snoop signal is supposed to go high whenever the data in the cache is not in an invalid state and the cache tag matches the tag address being snooped. In this situation, the test case matched the requirements but the signal was still low.



## 4. Debugging:

The access\_blk\_snoop signal is controlled by the access\_blk\_snoop\_md file which ensures that the signal goes high when above conditions are met. This is triggered by signals such as bus read and bus\_readx in the original file. However, according to the HAS document, the Invalidate signal is also responsible for triggering the snoop mechanism in the design. This meant that the snoop mechanism was not getting triggered by Invalidate. Hence, we added the Invalidate

signal in the sensitivity list of the if loop in access\_blk\_snoop\_md to ensure access\_blk\_snoop is high every time the Invalidate signal goes high and the conditions are met.

- 5. Erroneous RTL file name access\_blk\_snoop\_md.sv
- **6.** Lines of RTL file responsible for the bug: if(bus\_rd || bus\_rdx) begin
- 7. Corrected RTL code: if(bus\_rd || bus\_rdx || invalidate) begin
- 8. Corrected Wave Form:

